<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div{
            width: 20px;
            height: 20px;
            text-align: center;
            line-height: 20px;
            background-color: #f00;
            position: absolute;
            border-radius: 50%;
        }
    </style>
</head>
<body>

    <!-- <div></div> -->

    <script>

        var fragment = document.createDocumentFragment() ;
        for(var i = 0 ; i < 30 ; i++) {
            var oDiv = document.createElement('div') ;
            oDiv.innerHTML = i + 1 ;
            fragment.appendChild(oDiv) ;
        }
        document.body.appendChild(fragment) ;


        var oDivs = document.querySelectorAll('div') ;
        var t ;

        document.onkeydown = function(e) {
            clearInterval(t) ;
            t = setInterval(function(){
                // 在盒子原来位置的基础上增加值或者减少值
                var x = oDivs[0].offsetLeft ;
                var y = oDivs[0].offsetTop ;

                var code = e.keyCode || e.which ;
                console.log(code);

                // 下
                if(code === 40) {
                    y += 20 ;
                }
                // 右
                else if(code === 39) {
                    x += 20 ;
                }
                // 上
                else if(code === 38) {
                    y -= 20 ;
                }
                // 左
                else if(code === 37) {
                    x -= 20 ;
                }

                oDivs[0].style.left = x + 'px' ;
                oDivs[0].style.top = y + 'px' ;

                for(var i = oDivs.length - 1 ; i > 0 ; i--) {
                    oDivs[i].style.left = oDivs[i - 1].style.left ;
                    oDivs[i].style.top = oDivs[i - 1].style.top ;
                }


            },120)
        }

    </script>
    
</body>
</html>